home *** CD-ROM | disk | FTP | other *** search
- <?php
- /* $Id: server_databases.php,v 2.14 2004/12/29 12:31:43 nijel Exp $ */
- // vim: expandtab sw=4 ts=4 sts=4:
-
-
- /**
- * Checks if the left frame has to be reloaded
- */
- require_once('./libraries/grab_globals.lib.php');
-
-
- /**
- * Does the common work
- */
- $js_to_run = 'functions.js';
- require('./server_common.inc.php');
-
- ?>
- <script type="text/javascript" language="javascript1.2">
- <!--
- function reload_window(db) {
- if (typeof(window.parent) != 'undefined'
- && typeof(window.parent.frames['nav']) != 'undefined') {
- window.parent.frames['nav'].goTo('./left.php?<?php echo PMA_generate_common_url('','','&');?>&db=' + db + '&hash=' + <?php echo (($cfg['QueryFrame'] && $cfg['QueryFrameJS']) ? 'window.parent.frames[\'queryframe\'].document.hashform.hash.value' : "'" . md5($cfg['PmaAbsoluteUri']) . "'"); ?>);
- }
- }
- //-->
- </script>
-
- <?php
-
- /**
- * Sorts the databases array according to the user's choice
- *
- * @param array a record associated to a database
- * @param array a record associated to a database
- *
- * @return integer a value representing whether $a should be before $b in the
- * sorted array or not
- *
- * @global string the column the array shall be sorted by
- * @global string the sorting order ('asc' or 'desc')
- *
- * @access private
- */
- function PMA_dbCmp($a, $b)
- {
- global $sort_by, $sort_order;
- if ($GLOBALS['cfg']['NaturalOrder']) {
- $sorter = 'strnatcmp';
- } else {
- $sorter = 'strcasecmp';
- }
- if ($sort_by == 'db_name') {
- return ($sort_order == 'asc' ? 1 : -1) * $sorter($a['db_name'], $b['db_name']);
- } else if ($a[$sort_by] == $b[$sort_by]) {
- return $sorter($a['db_name'], $b['db_name']);
- } else {
- return ($sort_order == 'asc' ? 1 : -1) * ((int)$a[$sort_by] > (int)$b[$sort_by] ? 1 : -1);
- }
- } // end of the 'PMA_dbCmp()' function
-
-
- /**
- * Gets the databases list - if it has not been built yet
- */
- if ($server > 0 && empty($dblist)) {
- PMA_availableDatabases();
- }
-
-
- /**
- * Drops multiple databases
- */
- if ((!empty($drop_selected_dbs) || isset($query_type)) && ($is_superuser || $cfg['AllowUserDropDatabase'])) {
- if (empty($selected_db) && ! (isset($query_type) && !empty($selected))) {
- $message = $strNoDatabasesSelected;
- } else {
- $action = 'server_databases.php';
- $submit_mult = 'drop_db' ;
- $err_url = 'server_databases.php?' . PMA_generate_common_url();
- require('./mult_submits.inc.php');
- $message = sprintf($strDatabasesDropped, count($selected));
- // we need to reload the database list now.
- PMA_availableDatabases();
- $reload = 1;
- }
- }
-
-
- /**
- * Displays the links
- */
- require('./server_links.inc.php');
-
-
- /**
- * Displays the sub-page heading
- */
- echo '<h2>' . "\n"
- . ($GLOBALS['cfg']['MainPageIconic'] ? '<img src="' . $pmaThemeImage . 's_db.png" border="0" hsape="2" align="middle" width="16" height="16" />' : '')
- . ' ' . (empty($dbstats) ? $strDatabases : $strDatabasesStats) . "\n"
- . '</h2>' . "\n";
-
-
- /**
- * Checks if the user is allowed to do what he tries to...
- */
- if (!empty($dbstats) && !$is_superuser) {
- echo $strNoPrivileges . "\n";
- require_once('./footer.inc.php');
- }
-
-
- /**
- * Prepares the statistics
- */
- $statistics = array();
- foreach ($dblist AS $current_db) {
- $tmp_array = array(
- 'db_name' => $current_db,
- 'tbl_cnt' => 0,
- 'data_sz' => 0,
- 'idx_sz' => 0,
- 'tot_sz' => 0
- );
- if (!empty($dbstats)) {
- $res = PMA_DBI_query('SHOW TABLE STATUS FROM ' . PMA_backquote($current_db) . ';');
- while ($row = PMA_DBI_fetch_assoc($res)) {
- $tmp_array['tbl_cnt']++;
- $tmp_array['data_sz'] += $row['Data_length'];
- $tmp_array['idx_sz'] += $row['Index_length'];
- }
- PMA_DBI_free_result($res);
- unset($res);
- }
- $tmp_array['tot_sz'] = $tmp_array['data_sz'] + $tmp_array['idx_sz'];
- $statistics[] = $tmp_array;
- }
-
- // avoids 'undefined index' errors
- if (empty($sort_by)) {
- $sort_by = 'db_name';
- }
- if (empty($sort_order)) {
- if ($sort_by == 'db_name') {
- $sort_order = 'asc';
- } else {
- $sort_order = 'desc';
- }
- }
-
- // sorts the array
- usort($statistics, 'PMA_dbCmp');
-
-
- /**
- * Displays the page
- */
- if (count($statistics) > 0) {
- echo '<form action="./server_databases.php" method="post" name="dbStatsForm">' . "\n"
- . PMA_generate_common_hidden_inputs('', '', 1)
- . ' <input type="hidden" name="dbstats" value="' . (empty($dbstats) ? '0' : '1') . '" />' . "\n"
- . ' <input type="hidden" name="sort_by" value="' . $sort_by . '" />' . "\n"
- . ' <input type="hidden" name="sort_order" value="' . $sort_order . '" />' . "\n"
- . ' <table border="0" cellpadding="2" cellspacing="1">' . "\n"
- . ' <tr>' . "\n"
- . ($is_superuser || $cfg['AllowUserDropDatabase'] ? ' <th> </th>' . "\n" : '')
- . ' <th>' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . (!empty($dbstats) ? '&dbstats=1' : '') . '&sort_by=db_name&sort_order=' . (($sort_by == 'db_name' && $sort_order == 'asc') ? 'desc' : 'asc') . '">' . "\n"
- . ' ' . $strDatabase . "\n"
- . ($sort_by == 'db_name' ? ' <img src="' . $pmaThemeImage . 's_' . $sort_order . '.png" border="0" width="11" height="9" alt="' . ($sort_order == 'asc' ? $strAscending : $strDescending) . '" />' . "\n" : '')
- . ' </a>' . "\n"
- . ' ' . "\n"
- . ' </th>' . "\n";
- if (!empty($dbstats)) {
- if (PMA_MYSQL_INT_VERSION >= 40101) {
- echo ' <th>' . "\n"
- . ' ' . $strCollation . ' ' . "\n"
- . ' </th>' . "\n";
- }
- echo ' <th>' . "\n"
- . ' ' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . '&dbstats=1&sort_by=tbl_cnt&sort_order=' . (($sort_by == 'tbl_cnt' && $sort_order == 'desc') ? 'asc' : 'desc') . '">' . "\n"
- . ' ' . $strNumTables . "\n"
- . ($sort_by == 'tbl_cnt' ? ' <img src="' . $pmaThemeImage . 's_' . $sort_order . '.png" border="0" width="11" height="9" alt="' . ($sort_order == 'asc' ? $strAscending : $strDescending) . '" />' . "\n" : '')
- . ' </a>' . "\n"
- . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th colspan="2">' . "\n"
- . ' ' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . '&dbstats=1&sort_by=data_sz&sort_order=' . (($sort_by == 'data_sz' && $sort_order == 'desc') ? 'asc' : 'desc') . '">' . "\n"
- . ' ' . $strData . "\n"
- . ($sort_by == 'data_sz' ? ' <img src="' . $pmaThemeImage . 's_' . $sort_order . '.png" border="0" width="11" height="9" alt="' . ($sort_order == 'asc' ? $strAscending : $strDescending) . '" />' . "\n" : '')
- . ' </a>' . "\n"
- . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th colspan="2">' . "\n"
- . ' ' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . '&dbstats=1&sort_by=idx_sz&sort_order=' . (($sort_by == 'idx_sz' && $sort_order == 'desc') ? 'asc' : 'desc') . '">' . "\n"
- . ' ' . $strIndexes . "\n"
- . ($sort_by == 'idx_sz' ? ' <img src="' . $pmaThemeImage . 's_' . $sort_order . '.png" border="0" width="11" height="9" alt="' . ($sort_order == 'asc' ? $strAscending : $strDescending) . '" />' . "\n" : '')
- . ' </a>' . "\n"
- . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th colspan="2">' . "\n"
- . ' ' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . '&dbstats=1&sort_by=tot_sz&sort_order=' . (($sort_by == 'tot_sz' && $sort_order == 'desc') ? 'asc' : 'desc') . '">' . "\n"
- . ' ' . $strTotalUC . "\n"
- . ($sort_by == 'tot_sz' ? ' <img src="' . $pmaThemeImage . 's_' . $sort_order . '.png" border="0" width="11" height="9" alt="' . ($sort_order == 'asc' ? $strAscending : $strDescending) . '" />' . "\n" : '')
- . ' </a>' . "\n"
- . ' ' . "\n"
- . ' </th>' . "\n";
- }
- if ($is_superuser) {
- echo ' <th>' . "\n"
- . ' ' . ($cfg['PropertiesIconic'] ? '' : $strAction . ' ') . "\n"
- . ' </th>' . "\n";
- }
- echo ' </tr>' . "\n";
- $useBgcolorOne = TRUE;
- $total_calc = array(
- 'db_cnt' => 0,
- 'tbl_cnt' => 0,
- 'data_sz' => 0,
- 'idx_sz' => 0,
- 'tot_sz' => 0
- );
- foreach ($statistics as $current) {
- list($data_size, $data_unit) = PMA_formatByteDown($current['data_sz'], 3, 1);
- list($idx_size, $idx_unit) = PMA_formatByteDown($current['idx_sz'], 3, 1);
- list($tot_size, $tot_unit) = PMA_formatByteDown($current['tot_sz'], 3, 1);
- $total_calc['db_cnt']++;
- $total_calc['tbl_cnt'] += $current['tbl_cnt'];
- $total_calc['data_sz'] += $current['data_sz'];
- $total_calc['idx_sz'] += $current['idx_sz'];
- $total_calc['tot_sz'] += $current['tot_sz'];
- echo ' <tr>' . "\n";
- if ($is_superuser || $cfg['AllowUserDropDatabase']) {
- echo ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '">' . "\n"
- . ' <input type="checkbox" name="selected_db[]" title="' . htmlspecialchars($current['db_name']) . '" value="' . htmlspecialchars($current['db_name']) . '" ' . (empty($checkall) ? '' : 'checked="checked" ') . '/>' . "\n"
- . ' </td>' . "\n";
- }
- echo ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '">' . "\n"
- . ' <a onclick="reload_window(\'' . urlencode($current['db_name']) . '\'); return true;" href="' . $cfg['DefaultTabDatabase'] . '?' . $url_query . '&db=' . urlencode($current['db_name']) . '" title="' . sprintf($strJumpToDB, htmlspecialchars($current['db_name'])) . '">' . "\n"
- . ' ' . htmlspecialchars($current['db_name']) . "\n"
- . ' </a>' . "\n"
- . ' </td>' . "\n";
- if (!empty($dbstats)) {
- if (PMA_MYSQL_INT_VERSION >= 40101) {
- $current_collation = PMA_getDbCollation($current['db_name']);
- echo ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '">' . "\n"
- . ' <dfn title="' . htmlspecialchars(PMA_getCollationDescr($current_collation)) . '">' . "\n"
- . ' ' . htmlspecialchars($current_collation) . "\n"
- . ' </dfn>' . "\n"
- . ' </td>' . "\n";
- }
- echo ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '" align="right">' . "\n"
- . ' ' . $current['tbl_cnt'] . "\n"
- . ' </td>' . "\n"
- . ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '" align="right">' . "\n"
- . ' ' . $data_size . "\n"
- . ' </td>' . "\n"
- . ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '">' . "\n"
- . ' ' . $data_unit . "\n"
- . ' </td>' . "\n"
- . ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '" align="right">' . "\n"
- . ' ' . $idx_size . "\n"
- . ' </td>' . "\n"
- . ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '">' . "\n"
- . ' ' . $idx_unit . "\n"
- . ' </td>' . "\n"
- . ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '" align="right">' . "\n"
- . ' <b>' . "\n"
- . ' ' . $tot_size . "\n"
- . ' </b>' . "\n"
- . ' </td>' . "\n"
- . ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '">' . "\n"
- . ' <b>' . "\n"
- . ' ' . $tot_unit . "\n"
- . ' </b>' . "\n"
- . ' </td>' . "\n";
- }
- if ($is_superuser) {
- echo ' <td bgcolor="' . ($useBgcolorOne ? $cfg['BgcolorOne'] : $cfg['BgcolorTwo']) . '" align="center">' . "\n"
- . ' <a onclick="reload_window(\'' . urlencode($current['db_name']) . '\'); return true;" href="./server_privileges.php?' . $url_query . '&checkprivs=' . urlencode($current['db_name']) . '" title="' . sprintf($strCheckPrivsLong, htmlspecialchars($current['db_name'])) . '">'. "\n"
- . ' ' .($cfg['PropertiesIconic'] ? '<img src="' . $pmaThemeImage . 's_rights.png" width="16" height="16" hspace="2" border="0" alt=" ' .$strCheckPrivs . '" /> ' : $strCheckPrivs ). "\n"
- . ' </a>' . "\n"
- . ' </td>' . "\n";
- }
- echo ' </tr>' . "\n";
- $useBgcolorOne = !$useBgcolorOne;
- } // end while
- if (!empty($dbstats)) {
- list($data_size, $data_unit) = PMA_formatByteDown($total_calc['data_sz'], 3, 1);
- list($idx_size, $idx_unit) = PMA_formatByteDown($total_calc['idx_sz'], 3, 1);
- list($tot_size, $tot_unit) = PMA_formatByteDown($total_calc['tot_sz'], 3, 1);
- echo ' <tr>' . "\n"
- . ' <th> </th>' . "\n"
- . ' <th>' . "\n"
- . ' ' . $strTotalUC . ': ' . $total_calc['db_cnt'] . ' ' . "\n"
- . ' </th>' . "\n";
- if (PMA_MYSQL_INT_VERSION >= 40101) {
- echo ' <th> </th>' . "\n";
- }
- echo ' <th align="right">' . "\n"
- . ' ' . $total_calc['tbl_cnt'] . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th align="right">' . "\n"
- . ' ' . $data_size . "\n"
- . ' </th>' . "\n"
- . ' <th align="left">' . "\n"
- . ' ' . $data_unit . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th align="right">' . "\n"
- . ' ' . $idx_size . "\n"
- . ' </th>' . "\n"
- . ' <th align="left">' . "\n"
- . ' ' . $idx_unit . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th align="right">' . "\n"
- . ' ' . $tot_size . "\n"
- . ' </th>' . "\n"
- . ' <th align="left">' . "\n"
- . ' ' . $tot_unit . ' ' . "\n"
- . ' </th>' . "\n"
- . ' <th> </th>' . "\n"
- . ' </tr>' . "\n";
- }
- if ($is_superuser || $cfg['AllowUserDropDatabase']) {
- $common_url_query = PMA_generate_common_url() . '&sort_by=' . $sort_by . '&sort_order=' . $sort_order . '&dbstats=' . (empty($dbstats) ? '10' : '3');
- echo ' <tr>' . "\n"
- . ' <td colspan="' . (empty($dbstats) ? '10' : '3') . '">' . "\n"
- . ' <img src="' . $pmaThemeImage . 'arrow_' . $text_dir . '.png" border="0" width="38" height="22" alt="' . $strWithChecked . '" />' . "\n"
- . ' <a href="./server_databases.php?' . $common_url_query . '&checkall=1" onclick="setCheckboxes(\'dbStatsForm\', true); return false;">' . "\n"
- . ' ' . $strCheckAll
- . ' </a>' . "\n"
- . ' / ' . "\n"
- . ' <a href="./server_databases.php?' . $common_url_query . '" onclick="setCheckboxes(\'dbStatsForm\', false); return false;">' . "\n"
- . ' ' . $strUncheckAll
- . ' </a>' . "\n"
- . ' </td>' . "\n"
- . ' </tr>' . "\n";
- }
- echo ' </table>' . "\n";
- unset($data_size);
- unset($data_unit);
- unset($idx_size);
- unset($idx_unit);
- unset($tot_size);
- unset($tot_unit);
- if ($is_superuser || $cfg['AllowUserDropDatabase']) {
- echo ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<br /><table border="0" cellpadding="2" cellspacing="0">' : '<ul>') . "\n";
- }
- if ($is_superuser && empty($dbstats)) {
- echo ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<tr><td colspan="2">' : '<li>') . "\n"
- . ' <b>' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . '&dbstats=1" title="' . $strDatabasesStatsEnable . '">' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<img src="' .$pmaThemeImage . 'b_dbstatistics.png" width="16" height="16" border="0" hspace="2" align="middle" />' : '') . "\n"
- . ' ' . $strDatabasesStatsEnable . "\n"
- . ' </a>' . "\n"
- . ' </b>' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '</td></tr><tr><td width="20" nowrap="nowrap"> </td><td>' : '<br />') . "\n"
- . ' ' . $strDatabasesStatsHeavyTraffic . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<br /> </td></tr>' : '</li>') . "\n";
- } else if ($is_superuser && !empty($dbstats)) {
- echo ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<tr><td colspan="2">' : '<li>') . "\n"
- . ' <b>' . "\n"
- . ' <a href="./server_databases.php?' . $url_query . '" title="' . $strDatabasesStatsDisable . '">' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<img src="' .$pmaThemeImage . 'b_dbstatistics.png" width="16" height="16" border="0" hspace="2" align="middle" />' : '') . "\n"
- . ' ' . $strDatabasesStatsDisable . "\n"
- . ' </a>' . "\n"
- . ' </b>' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<br /> </td></tr>' : '<br /></li>') . "\n";
- }
- if ($is_superuser || $cfg['AllowUserDropDatabase']) {
- echo ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<tr><td colspan="2">' : '<li>') . "\n"
- . ' <b>' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<img src="' .$pmaThemeImage . 'b_deltbl.png" width="16" height="16" border="0" hspace="2" align="middle" />' : '') . "\n"
- . ' ' . $strDropSelectedDatabases . "\n"
- . ' </b>' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '</td></tr><tr><td width="20" nowrap="nowrap"> </td><td nowrap="nowrap" align="left" width="400">' : '<br />') . "\n"
- . ' <input type="submit" name="drop_selected_dbs" value="' . $strDrop . '" id="buttonNo" />' . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '<br /> </td></tr>' : '</li>') . "\n"
- . ' ' . ($GLOBALS['cfg']['PropertiesIconic'] ? '</table>' : '</ul>') . "\n";
- }
- echo '</form>' . "\n";
- } else {
- echo $strNoDatabases . "\n";
- }
-
- /**
- * Create new database.
- */
- ?>
-
- <form method="post" action="db_create.php"><b>
- <?php echo $strCreateNewDatabase . ' ' . PMA_showMySQLDocu('Reference', 'CREATE_DATABASE'); ?></b><br />
- <?php echo PMA_generate_common_hidden_inputs('', '', 5); ?>
- <input type="hidden" name="reload" value="1" />
- <input type="text" name="db" value="" maxlength="64" class="textfield" />
- <?php
- if (PMA_MYSQL_INT_VERSION >= 40101) {
- require_once('./libraries/mysql_charsets.lib.php');
- echo PMA_generateCharsetDropdownBox(PMA_CSDROPDOWN_COLLATION, 'db_collation', NULL, NULL, TRUE, 5);
- }
- ?>
- <input type="submit" value="<?php echo $strCreate; ?>" id="buttonGo" />
- </form>
-
- <?php
-
- /**
- * Sends the footer
- */
- require_once('./footer.inc.php');
-
- ?>
-